<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
  <meta charset="utf-8">
  <title>用户管理</title>
  <meta name="renderer" content="webkit">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
  <link rel="stylesheet" th:href="@{/layui/css/layui.css}" media="all">
  <link rel="stylesheet" th:href="@{/adminui/dist/css/admin.css}" media="all">
  <link rel="stylesheet" th:href="@{/style/custom.css}" media="all">
</head>
<body>

<div class="layui-fluid">
  <div class="layui-card">
    <div class="layui-form layui-card-header layuiadmin-card-header-auto layui-form-pane" lay-filter="LAY-user-front-form">
      <div class="layui-form-item">
        <div class="layui-inline">
          <label class="layui-form-label">用户ID</label>
          <div class="layui-input-block">
            <input type="text" name="userId" placeholder="请输入" autocomplete="off" class="layui-input" lay-affix="clear">
          </div>
        </div>
        <div class="layui-inline">
          <label class="layui-form-label">用户名</label>
          <div class="layui-input-block">
            <input type="text" name="username" placeholder="请输入" autocomplete="off" class="layui-input" lay-affix="clear">
          </div>
        </div>
        <div class="layui-inline">
          <label class="layui-form-label">所属组织</label>
          <div class="layui-input-block" id="orgId" style="width: 186px;margin-top: 1px;">
          </div>
        </div>
        <div class="layui-inline">
          <button class="layui-btn layui-btn-normal layui-btn-sm" lay-submit lay-filter="LAY-user-front-search">
            <i class="layui-icon layui-icon-search layuiadmin-button-btn"></i> 搜索
          </button>
          <button class="layui-btn layui-btn-primary layui-btn-sm" lay-submit lay-filter="LAY-user-front-reset">
            <i class="layui-icon layui-icon-refresh layuiadmin-button-btn"></i> 重置
          </button>
        </div>
      </div>
    </div>

    <div class="layui-card-body">
      <div class="layui-btn-group" style="padding-bottom: 10px;">
        <!--刷新table-->
        <button type="button" class="layui-btn layui-btn-normal btn-op-user layui-btn-sm" data-type="refresh">
          <i class="layui-icon">&#xe666;</i>刷新
        </button>
        <!-- 新增 -->
        <button type="button" class="layui-btn layui-btn-normal btn-op-user layui-btn-sm" data-type="add">
          <i class="layui-icon">&#xe654;</i>新增
        </button>
      </div>

      <!--table 定义-->
      <table id="LAY-user-table" lay-filter="LAY-user-table"></table>
      <!--table 列转换-->
      <script type="text/html" id="imgTpl">
        <img style="display: inline-block; width: 50%; height: 100%;" src={{ d.avatar }}>
      </script>
      <script type="text/html" id="statusSwitchTpl">
        <input type="checkbox" disabled name="status" value="{{d.status}}" lay-skin="switch" lay-text="启用|禁用" {{ d.status== 'Y' ?'checked' : '' }}>
      </script>

      <!--列表操作项-->
      <script type="text/html" id="user-table">
        <a class="layui-btn layui-btn-normal layui-btn-xs" lay-event="edit"><i class="layui-icon layui-icon-edit"></i>编辑</a>
        <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del"><i class="layui-icon layui-icon-delete"></i>删除</a>
      </script>
    </div>
  </div>
</div>

<script th:src="@{/layui/layui.js}"></script>
<script>
  layui.config({
    base: '/'
  }).extend({
    //设定模块别名，模块名是使用layui.模块名  模块文件是 js名字。不设置模块名 = 模块文件名
    useradmin: 'modules/cm/useradmin',
    xmSelect: 'extend/xm-select/dist/xm-select'
  }).use(['useradmin', 'xmSelect'], function(){
    let admin = layui.admin;
    let form = layui.form;
    let table = layui.table;
    let xmSelect = layui.xmSelect;

    //所属组织
    let orgId_select = xmSelect.render({
      el: '#orgId',
      name: 'orgId',
      // layVerify: 'required',
      layVerType: 'msg',
      //显示为text模式
      model: {label: {type: 'text'}},
      //单选模式
      radio: true,
      //选中关闭
      clickClose: true,
      toolbar: {
        show: true,
        list: ['CLEAR']
      },
      filterable: true,
      //树
      tree: {
        show: true,
        //非严格模式
        strict: false,
        //展开所有节点
        expandedKeys: true,
      },
      data: []
    });

    //加载组织机构下拉选
    admin.req({
      url: '/organization/getOrganizationSelectList',
      type: 'post',
      done: function (res) {
        orgId_select.update({
          data: res.data,
          autoRow: true,
        });
        //异步远程加载数据，需要重新设置
        orgId_select.changeExpandedKeys(true);
      }
    });


    //监听搜索
    form.on('submit(LAY-user-front-search)', function (data) {
      let field = data.field;
      //执行重载
      table.reload('LAY-user-table', {
        where: field
      });
    });
    // 监听重置
    form.on('submit(LAY-user-front-reset)', function (data) {
      let field = data.field;
      for (let key of Object.keys(field)) {
        field[key] = '';
      }
      form.val("LAY-user-front-form", field);

      orgId_select.setValue([]);
    });


    //事件
    let active = {
      add: function () {
        layer.open({
          type: 2
          , title: '新增'
          , content: '/user/turn/edit'
          , area: ['98.3%', '98.3%']
          , resize: false
          , yes: function (index, layero) {
          }
          , cancel: function (index, layero) {
            layer.close(index);
            //数据刷新
            table.reload('LAY-user-table');
            return false;
          }
          , end: function () {
            //数据刷新
            table.reload('LAY-user-table');
          }
        });
      }
      , refresh: function () {
        let data = form.val("LAY-user-front-form");
        //执行重载 数据刷新
        table.reload('LAY-user-table', {
          where: data
        });
      }
    };

    //执行事件操作
    layui.$('.layui-btn.btn-op-user').on('click', function () {
      let type = layui.$(this).data('type');
      active[type] ? active[type].call(this) : '';
    });


  });
</script>
</body>
</html>
